# AURIX 2G Standby Controller(SCR) Overview

Thomas
IFCN ATV SMD GC SAE MC
2018/5/2





## History List / Changes

Module Name: Standby Controller (SCR)

Module Owner: Angel Berrio Moreno

Slide Target: SCR Overview

Slide Version: 3.0

Slide Status: Released

Last Modification: 23/06/2017

Revision History:

1.0 First version

2.0 Added specific features of A2G
 and peripheral description

 3.0 Added changes available in the latest version of the IP



- 1 Overview
- 2 System Architecture : Standby Domain
- 3 SCR Architecture
- 4 Debug system
- 5 SCR SW Framework



- 1 Overview
- 2 System Architecture : Standby Domain
- 3 SCR Architecture
- 4 Debug system
- 5 SCR SW Framework



### Overview

- Support High Performance and low power standby using one silicon
- Two separate core domains
  - A "high performance" domain (Tricore)
    - only needed if engine is on, otherwise, switched off
  - A "low power" domain (SCR)
    - Permanently on
    - All features available to do supervising tasks.
    - Wakeup of high performance domain only needed, when the car is started
- Two separate IO domains
  - A domain is powered during standby mode while all other pins are switched off



- 1 Overview
- 2 System Architecture : Standby Domain
- 3 SCR Architecture
- 4 Debug system
- 5 SCR SW Framework



# System Architecture: Standby Domain



- Standby Mode: Low Power Mode
- Cores, Peripherals powered off
- Only Standby Domain is powered
- Wake-up possible from different sources. Eg: Ports/ESR, SCR etc.

- Standby RAM:
  - CPU0 and CPU1 dLMU can be kept powered on
  - Data retained during standby
- Pads: Pad control possible via SCR
- From 100MHz to 70kHz clock



- 1 Overview
- 2 System Architecture : Standby Domain
- 3 SCR Architecture
- 4 Debug system
- 5 SCR SW Framework



## SCR Architecture: SCR in the System

- Standby Controller: 8-bit Controller
  - XC800 Core + peripherals
  - 8KB XRAM for code / data accesible via FPI slave interface
- Some signals to/from SCU
- Interrupts to/from main system
- Ports shared between Tricore & SCR
  - Can select the owner of the port



### **SCR Architecture**

- Supports various supervising tasks
  - Real-time clock for periodic wake-up
  - LIN possible via UART
  - SPI via SSC
  - Shared I/O pins including wake-up pins
  - Wakeup-CAN filter
  - On-chip SRAM for data and code
- Very low current consumption ~μA range (70kHz)
- Existing proven solution: XC800 based 8-Bit controller



### SCR Architecture: A1G vs A2G





# SCR Architecture – Watchdog Timer

- 16-bit Watchdog Timer
- Programmable reload value for upper 8 bits of timer and window boundary
- Clock source from either the 70kHz clock or the 100MHz/DIV clock
- Selectable input frequency of fWDTCLK/2 or fWDTCLK/128





### SCR Architecture – Real-Time Clock

- Periodic Wake-up Mode using either the 70kHz clock or the 100MHz/DIV clock
- Wake-up source during standby mode





# SCR Architecture - Timer & Capture

- Timer 0, Timer 1 and Timer 2
  - 8-bit(with auto reload), two 8bit timers, 13-bit timer and 16-bit timer modes



#### T2CCU

 16-bit resolution, 6 compare channels, shadow register for each compare register





### SCR Architecture – Serial Communication

### UART/LIN

- 8 and 9 bits UART with configurable Baud Rate
- LIN Automatic
   Synchronization to the Host
- LIN Baud Rate Detection



### SSC (SPI)

- Full-duplex and half-duplex sync. communication up to 2MB
- Master and Slave support,
   Flexible data format
- Receive FIFO (4 stages)





### SCR Architecture – ADC Comparator Unit

- 8-bit resolution, LSB = 23,077mV, Range = 0 5861,54mV.
- Accuracy / TUE = +-3LSB
- 4 ADC channels
- 200ns sampling time + 400ns conversion time.





### SCR Architecture – Wake-up CAN Filter

- Receive and Wake-up CAN operation according to ISO11898-6
- 1 Wake-up CAN node mapped to CAN 0
- Tolerant to CAN FD frames
- Data transfer rates guaranteed until 500kBaud



WCAN\_block\_diag.vsd



- 1 Overview
- 2 System Architecture : Standby Domain
- 3 SCR Architecture
- 4 Debug system
- 5 SCR SW Framework



# Debug system





## Debug system: Normal running mode

- Debug both TriCore and SCR in parallel.
  - TriCore running some code All normal debug functions available.
  - SCR:
    - Can program XRAM with some code.
    - Read/write XRAM + direct / indirect addressed SFRs
    - Read/write 8051 CPU registers.
    - Access SCR peripherals.
    - Normal debug functions: Breakpoints etc.
    - Access via SPD/DAP0 or DAP1



# Debug system: Standby mode

- In standby mode, interface via main SoC DAP is not available (Main system in standby)
- Therefore, debug access via SCR private DAP pins.
  - Similar to previous:
    - Can program XRAM with some code.
    - Read/write XRAM + direct / indirect addressed SFRS
    - Read/write 8051 CPU registers.
    - Access SCR peripherals.
    - Normal debug functions: Breakpoints etc.
    - Access via SPD/DAP0 or DAP1



- 1 Overview
- 2 System Architecture : Standby Domain
- 3 SCR Architecture
- 4 Debug system
- 5 SCR SW Framework



### SCR SW Framework

- BaseFramework\_TC39xA\_SCR\_TC\_WakeUP Config Scr Scr Main ScrSoC > 

  I\_SrvSw > A\_McHal D Utilities arch\_scr.lsl CfgCompiler\_Dcc.mk lacktrian Compiler\_Gnuc.mk CfgCompiler\_Tasking.mk CfgCompiler\_Tool3rdCpu.mk 🚡 CfgDoxygen.mk CfgIndent.mk ConfigPrj.mk Lcf\_Dcc.lsl Lcf\_Gnuc.lsl Lcf\_Tasking.lsl Lcf\_Tool3rdCpu.lsl > 

  I\_SrvSw > A McHal 为 0 Src.mk
- SCR integrated as 3rd-CPU in SW Framework (Scr)
- > Tricore/ScrSoC: SoC side of the code
- Tasking compiler support (Both Tricore and 8051)
  - 0\_Src.mk including both make files:
    - TOOLCHAIN\_DIR\_MAIN:= ...\TASKING\TriCore v6.0r1\ctc
    - TOOLLIB\_DIR\_THIRD:= ...\TASKING\TriCore v6.0r1\c51\lib
  - CfgCompiler\_Tool3rdCpu.mk:

```
CARRAY="1_ToolEnv/0_Build/0_Utilities/iHex2Array.exe"
$(SCR_ARRAY): $(ELF_BIN_THIRD)
$(CARRAY) $(<:.elf=.hex) $(@:.o=.c)
$(CC) -o $(@:.o=.src) $(@:.o=.c) $(CC_OPTS)
$(AS) -o $@ $(@:.o=.src) $(ASM_OPTS)</pre>
```



# SCR SW Framework: Compilation (SCR code)

Generate intel-hex file in Out folder

- Simple Parser converts iHex to C-array
- C-array compiled into Tricore code
  - Included from
     0\_Src/0\_AppSw/Tricore/ScrSoC/IfxScr\_main.c

```
BaseFramework_TC39xA_SCR_TC_WakeUP_Scr.c ⋈
    /* Automatically generated array containing the SCR program */
    unsigned int scrProgramSize = 385;
    unsigned char scrProgram[385] = {
                           0x6.
                                   0x80.
                                            0xfe,
                                                     0x22,
                                                              0x75.
                                                                       0xd0
                                                                                0x0.
                                                                                         0x78
         0xf5,
                                                                       0xff,
                                                                                         0x8,
                                                                                                           0x12,
                 0xa0.
                                   0x81,
                                            0xd,
                                                     0x75,
                                                              0x9.
                                                                                0x75,
                                   0xff,
                                            0xfe,
                                                                                                           0x32,
                           0xe4.
                                                     0x12.
                                                              0x0.
                                                                       0x24
                                                                                0x12.
                                                                                         0x0.
         0x12,
                                   0x80,
                                            0xfe,
                                                     0xc0,
                                                              0xe0,
                                                                       0xc0
                                                                                0xd0,
                                                                                         0x75,
                                                                                                  0xd0
                                                                                                           0x0,
                  0xf5.
                                   0x75,
                                            0xfe,
                                                     0xdd,
                                                                                0x80,
                                                                                         0xd0,
                                                                                                  0xd0
                                                                                                           0xd0.
         0xe4.
                                                              0x75.
         0xe0,
                          0xc0.
                                   0xd0,
                                            0x75,
                                                     0xd0,
                                                              0x0,
                                                                                0xfe,
                                                                                         0xa,
                                                                                                  0x5,
                                                                                                           0xa,
                                   0x75,
                                            0xf6,
                                                     0x80,
                                                              0xd0,
                                                                       0xd0
                                                                                0x32,
                                                                                         0xe4,
                                                                                                  0xf5,
                                                                                                           0xeb,
         0x75,
                                   0x75,
                                            0xe9,
                                                     0x42,
                                                              0x75,
                                                                       0xe7,
                                                                                0x40.
                                                                                         0x75,
                                                                                                  0x95.
                                                                                                           0x17,
                                   0x0,
                                            0x0,
                                                     0x0,
                                                              0x0,
                                                                                0x0,
                                                                                         0x0,
                                   0x0.
                                            0x0.
                                                     0x0.
                                                              0x0.
                                                                                0x0.
                                                                                         0x29
                                                                                                  0xe4
                                                                                                           0xf5.
                                   0x40,
                                            0xf5.
                                                     0x8f,
                                                              0xf5,
                                                                       0xf1.
                                                                                0xf5,
                                                                                         0xf5,
                                                                                                           0xfe,
         0xac.
                          0x80
                                   0xf5.
                                            0xf6.
                                                     0xf5.
                                                              0xa8.
                                                                       0xf5.
                                                                                0xe8.
                                                                                         0x75.
                                                                                                  0xfe.
                                                                                                           0xa1.
                                   0xf1,
                                                     0x75,
                                                              0xfa,
                                                                                         0xf5,
                                                                                                           0x12,
                                                                                0xe4.
```

```
2 Out
   Tasking
   Tool3rdCpu
     RaseFramework TC39xA SCR TC WakeUP Scr.c
          BaseFramework_TC39xA_SCR_TC_WakeUP_Scr.hex
        BaseFramework_TC39xA_SCR_TC_WakeUP_Scr.ma

1 ToolEnv

  iHex2Array.exe
 Tasking
   Tool3rdCpu
        BaseFramework_TC39xA_SCR_TC_WakeUP_Scr.c
          BaseFramework TC39xA SCR TC WakeUP Scr.hex
        BaseFramework_TC39xA_SCR_TC_WakeUP_Scr.map
```



Part of your life. Part of tomorrow.

